An Encoder is a combinational circuit that performs the reverse operation of Decoder. It has maximum of 2<sup>n</sup> input lines and 'n' output lines. It will produce a binary code equivalent to the input, which is active High. Therefore, the encoder encodes 2<sup>n</sup> input lines with 'n' bits. It is optional to represent the enable signal in encoders.

## 4 to 2 Encoder Let 4 to 2 Encoder has four inputs Y3, Y2, Y1 & Y0 and two outputs A1 & A0. The block diagram of 4 to 2

 $Y_3$ 

Encoder is shown in the following figure.

$$\begin{array}{c} Y_2 \\ Y_1 \\ Y_0 \end{array} \begin{array}{c} 4 \text{ to } 2 \\ \text{Encoder} \end{array} \begin{array}{c} A_1 \\ A_0 \end{array}$$
 At any time, only one of these 4 inputs can be '1' in order to get the respective binary code at the output. The **Truth table** of 4 to 2 encoder is shown below.

0 0 0 1 0 0 0 0 1 0 0 1

 $Y_0$ 

 $Y_1$ 

 $Y_2$ 

| 0                 | 1                  | 0       | 0                             | 1                 | 0                  |
|-------------------|--------------------|---------|-------------------------------|-------------------|--------------------|
| 1                 | 0                  | 0       | 0                             | 1                 | 1                  |
| From Truth table, | , we can write the |         | ons for each output $Y_3+Y_2$ | t as              |                    |
|                   |                    | $A_0 =$ | $Y_3 + Y_1$                   |                   |                    |
|                   | nt the above two   |         | s by using two inp            | out OR gates. The | circuit diagram of |

Outputs

 $A_0$ 

Outputs

 $A_1$ 

0

0

1

1

 $A_0$ 

0

1

0

1

 $A_1$ 

 $Y_6$ 

0

0

0

0

Y5 -

 $Y_4$  ·

 $Y_7$ 

0

0

0

0

table of octal to binary encoder is shown below.

 $Y_5$ 

0

0

0

0

Inputs

 $Y_3$ 

0

0

0

1

 $Y_4$ 

0

0

0

0

0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0 0 1 0 1

At any time, only one of these eight inputs can be '1' in order to get the respective binary code. The Truth

Y<sub>2</sub>

0

0

1

0

 $Y_1$ 

0

1

0

0

 $Y_0$ 

1

0

0

0

A<sub>2</sub>

0

0

0

0

 $A_0$ 

The above circuit diagram contains three 4-input OR gates. These OR gates encode the eight inputs with three bits. Drawbacks of Encoder Following are the drawbacks of normal encoder. There is an ambiguity, when all outputs of encoder are equal to zero. Because, it could be the code corresponding to the inputs, when only least significant input is one or when all inputs are zero. If more than one input is active High, then the encoder produces an output, which may not be the correct code. For example, if both Y<sub>3</sub> and Y<sub>6</sub> are '1', then the encoder produces 111 at the output. This is neither equivalent code corresponding to Y3, when it is '1' nor the equivalent code corresponding to Y6, when it is '1'. So, to overcome these difficulties, we should assign priorities to each input of encoder. Then, the output of encoder will be the binary code corresponding to the active High input s, which has higher priority. This encoder is called as **priority encoder**. Priority Encoder A 4 to 2 priority encoder has four inputs Y<sub>3</sub>, Y<sub>2</sub>, Y<sub>1</sub> & Y<sub>0</sub> and two outputs A<sub>1</sub> & A<sub>0</sub>. Here, the input, Y<sub>3</sub> has the highest priority, whereas the input, Yo has the lowest priority. In this case, even if more than one input is '1' at the same time, the output will be the binary code corresponding to the input, which is having

We considered one more **output**, **V** in order to know, whether the code available at outputs is valid or not.

If at least one input of the encoder is '1', then the code available at outputs is a valid one. In this

If all the inputs of encoder are '0', then the code available at outputs is not a valid one. In this

 $Y_0$ 

0

1

Outputs

 $A_0$ 

0

0

0

1

A<sub>1</sub>

0

0

## 0 0

 $Y_3$ 

higher priority.

case, the output, V will be equal to 1.

case, the output, V will be equal to 0.

Y<sub>2</sub>

0

0

The **Truth table** of 4 to 2 priority encoder is shown below.

Inputs

 $Y_1$ 

0

0

0 1 0 0 1 0 1 1 0 From Truth table, we can write the **Boolean functions** for each output as 
$$A_1=Y_3+Y_2$$
 
$$A_0=Y_3+Y_1$$
 We can implement the above two Boolean functions by using two input OR gates. The **circuit diagram** 4 to 2 encoder is shown in the following figure.

The above circuit diagram contains two OR gates. These OR gates encode the four inputs with two bits Octal to Binary Encoder Octal to binary Encoder has eight inputs, Y7 to Y0 and three outputs A2, A1 & A0. Octal to binary encoder is nothing but 8 to 3 encoder. The **block diagram** of octal to binary Encoder is shown in the following figure. Octal to Binary  $Y_3$ Encoder

| 0                                                                                                                  | 0  | 1                                     | X                                                                       | 0                                   | 1                       | 1              |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------|----|---------------------------------------|-------------------------------------------------------------------------|-------------------------------------|-------------------------|----------------|--|--|--|--|
| 0                                                                                                                  | 1  | X                                     | x                                                                       | 1                                   | 0                       | 1              |  |  |  |  |
| 1                                                                                                                  | х  | x                                     | x                                                                       | 1                                   | 1                       | 1              |  |  |  |  |
| Use <b>4 variable</b>                                                                                              |    | etting simplified e                   | xpressions for e                                                        | ach output.<br>K-Map for            | · A <sub>0</sub>        |                |  |  |  |  |
|                                                                                                                    | 00 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Y <sub>3</sub> Y <sub>2</sub> 00 Y <sub>2</sub> 01 11 Y <sub>3</sub> 10 | Y <sub>0</sub> 00 01 11 1 1 1 1 1 1 | 1 ··· Y <sub>2</sub>    |                |  |  |  |  |
| $A_1=Y_3+Y_2$                                                                                                      |    |                                       |                                                                         |                                     |                         |                |  |  |  |  |
| $A_0 = Y_3 + Y_2 ' Y_1$<br>Similarly, we will get the Boolean function of output, V as $V = Y_3 + Y_2 + Y_1 + Y_0$ |    |                                       |                                                                         |                                     |                         |                |  |  |  |  |
| We can impler                                                                                                      |    | e Boolean functio<br>ving figure.     | ns using logic g                                                        | gates. The <b>circu</b>             | i <b>t diagram</b> of 4 | to 2 priority  |  |  |  |  |
| Y <sub>3</sub> . Y <sub>2</sub> .                                                                                  |    | ,                                     |                                                                         |                                     |                         | A <sub>1</sub> |  |  |  |  |
|                                                                                                                    |    |                                       |                                                                         | 7                                   |                         |                |  |  |  |  |

 $Y_0$ The above circuit diagram contains two 2-input OR gates, one 4-input OR gate, one 2input AND gate & an inverter. Here AND gate & inverter combination are used for producing a valid code at the outputs, even when multiple inputs are equal to '1' at the same time. Hence, this circuit encodes the four inputs with two bits based on the priority assigned to each input.